# **FIFO UVM Environment**



Created by:

**Mohamed Ahmed Mohamed Hussein** 

5/10/24

## **Verification Plan:**

| File                    |                                                                                             | U                                                              | sage                                                                                                            |                                                                                                                                                             |
|-------------------------|---------------------------------------------------------------------------------------------|----------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FIFO COVERAGE COLLECTOR | at functional coverage m                                                                    | netrics like whether all possil<br>s have been exercised. This | ble write-read comb                                                                                             | ghly the DUT has been tested. It look<br>inations, FIFO full/empty conditions,<br>es insight into how much of the desig                                     |
| Cover Point Name        | Description                                                                                 | Stimulus Generation                                            | Functional<br>Coverage                                                                                          | Functionality Check                                                                                                                                         |
| cp_wr_en                | A cover point used to monitor the behavior of the wr_en signal.                             | Directed at the beginning of FIFO_COVERAGE                     | Ooverage                                                                                                        | Checks if the wr_en signal transitions and how often it is asserted.                                                                                        |
| cp_rd_en                | A cover point used to monitor the behavior of the rd_en signal.                             | Directed during<br>FIFO_COVERAGE                               |                                                                                                                 | Checks if the rd_en signal<br>transitions and how often it is<br>asserted                                                                                   |
| cp_ack                  | A cover point used to observe when the wr_ack signal is generated.                          | Directed during<br>FIFO_COVERAGE                               |                                                                                                                 | Verifies that wr_ack is asserted correctly during valid write operations.                                                                                   |
| cp_overflow             | A cover point used to capture occurrences of FIFO overflow.                                 | Directed during<br>FIFO_COVERAGE                               |                                                                                                                 | Ensures the FIFO enters overflow<br>when it reaches capacity and a writ<br>attempt is made.                                                                 |
| cp_full                 | A cover point used to check when the FIFO is full.                                          | Directed during<br>FIFO_COVERAGE                               |                                                                                                                 | Observes the correct assertion of<br>the full signal when the FIFO<br>reaches its maximum depth.                                                            |
| cp_empty                | A cover point used to<br>capture occurrences of<br>FIFO being empty.                        | Directed during<br>FIFO_COVERAGE                               |                                                                                                                 | Validates that the FIFO empty flag i asserted when no data is present.                                                                                      |
| cp_almostfull           | A cover point used to<br>track when the FIFO is<br>almost full.                             | Directed during<br>FIFO_COVERAGE                               |                                                                                                                 | Monitors if almostfull is asserted just before the FIFO reaches capacity.                                                                                   |
| cp_almostempty          | A cover point used to track when the FIFO is almost empty.                                  | Directed during<br>FIFO_COVERAGE                               |                                                                                                                 | Checks if almostempty is asserted when only one data word remains in the FIFO.                                                                              |
| cp_underflow            | A cover point used to observe underflow conditions in the FIFO                              | Directed during<br>FIFO_COVERAGE                               |                                                                                                                 | Ensures that the underflow signal is asserted when a read operation is attempted while the FIFO is empty                                                    |
| Cross Coverage Name     | Description                                                                                 | Stimulus Generation                                            | Functional<br>Coverage                                                                                          | Functionality Check                                                                                                                                         |
| cp_wr_en_rd_en_cross    | A cross coverage point used to monitor the interaction between the wr_en and rd_en signals. | Directed during<br>FIFO_COVERAGE                               | Covers the simultaneous and independent assertion of wr_en and rd_en, ensuring all combinations are exercised.  | Verifies how often both wr_en and rd_en are asserted simultaneously or separately, ensuring proper operation during simultaneous read and write operations. |
| cp_wr_en_rst_n_cross    | A cross coverage point used to observe the relationship between wr_en and rst_n signals.    | Directed during<br>FIFO_COVERAGE                               | Covers the cases where wr_en is asserted or deasserted during both reset and non-reset states.                  | nanappe ni ie accunan                                                                                                                                       |
| cp_rd_en_rst_n_cross    | A cross coverage point used to monitor how rd_en behaves when rst_n is asserted.            | Directed during<br>FIFO_COVERAGE                               | Covers the interaction between rd_en and rst_n, ensuring rd_en is exercised in both reset and non-reset states. | Ensures that no read operations (rd_en) occur during reset (rst_n asserted).                                                                                |
| cp_wr_en_full_cross     | A cross coverage point used to check the relationship between wr_en and full signals.       | Directed during<br>FIFO_COVERAGE                               | Covers scenarios<br>where wr_en is<br>asserted when the<br>FIFO is full or not<br>full.                         | Verifies that the wr_en signal is no<br>asserted when the FIFO is full,<br>ensuring no writes happen in a full<br>FIFO.                                     |

| cp_rd_en_empty_cross       | A cross coverage point used to track the interaction between rd_en and empty signals.                     | Directed during<br>FIFO_COVERAGE     | Covers the behavior of rd_en when the FIFO is empty or not empty.                                             | Ensures that no read operations (rd_en) occur when the FIFO is empty, preventing underflow scenarios.                         |
|----------------------------|-----------------------------------------------------------------------------------------------------------|--------------------------------------|---------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|
| cp_wr_ack_wr_en_cross      | A cross coverage point used to monitor the relationship between wr_ack and wr_en signals.                 | Directed during<br>FIFO_COVERAGE     | Covers the different combinations of wr_en and wr_ack, ensuring correct handshaking between write operations. | Verifies that wr_ack is correctly asserted when valid write operations (wr_en) are performed.                                 |
| cp_rd_en_underflow_cross   | A cross coverage point used to track how rd_en behaves when underflow conditions occur.                   | Directed during<br>FIFO_COVERAGE     | Covers scenarios<br>where rd_en is<br>asserted in both<br>underflow and<br>normal conditions.                 | Ensures that underflow situations are properly handled when rd_en is asserted while the FIFO is empty.                        |
| cp_full_almostfull_cross   | A cross coverage point used to observe the relationship between full and almostfull signals.              | Directed during<br>FIFO_COVERAGE     | Covers the transition from almostfull to full, ensuring all boundary conditions are checked.                  | Verifies that the almostfull signal is asserted just before full is reached, ensuring correct behavior near full capacity.    |
| cp_full_almostfull_cross   | A cross coverage point used to observe the relationship between full and almostfull signals.              | Directed during<br>FIFO_COVERAGE     | Covers the transition from almostfull to full, ensuring all boundary conditions are checked.                  | Verifies that the almostfull signal is asserted just before full is reached, ensuring correct behavior near full capacity.    |
| cp_empty_almostempty_cross | A cross coverage point used to monitor the transition between empty and almostempty signals.              | Directed during<br>FIFO_COVERAGE     | Covers the transition between almostempty and empty, ensuring proper indication as the FIFO empties.          | Ensures that almostempty is asserted when only one word remains, and empty is asserted when no data is left                   |
| cp_overflow_wr_en_cross    | A cross coverage point used to capture overflow conditions when wr_en is asserted during full conditions. | Directed at the end of FIFO_COVERAGE | Covers the scenario where wr_en is asserted when the FIFO is full, checking for correct overflow detection.   | Verifies that overflow only happens when wr_en is asserted while the FIFO is full, ensuring proper handling of this scenario. |
|                            |                                                                                                           |                                      |                                                                                                               |                                                                                                                               |

| File            | Usage                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FIFO SCOREBOARD | The scoreboard is responsible for checking the functional correctness of the DUT as it has the reference model. It compares the expected results (predicted by a reference model or logic) with the actual outputs observed by the monitor. In your project, the FIFO_SCOREBOARD will verify that the data written into the FIFO is correctly read out and that any underflow or overflow conditions are handled properly. |

| File                   |                                                                                                                 | Us                                                  | age                                         |                                                                                                                     |
|------------------------|-----------------------------------------------------------------------------------------------------------------|-----------------------------------------------------|---------------------------------------------|---------------------------------------------------------------------------------------------------------------------|
| FIFO SVA               | properties. For example                                                                                         | e, assertions may ensure that                       | t the FIFO never ov<br>rigger if the DUT vi | ons (SVA) to check critical design<br>verflows or underflows and that data<br>olates any of the expected behaviors. |
| Assertion Name         | Description                                                                                                     | Stimulus Generation                                 | Functional<br>Coverage                      | Functionality Check                                                                                                 |
| reset assertion        | An immediate assertion used to verify that signals are correctly reset when rst_n is deasserted.                | Directed at the beginning of the design code (FIFO) |                                             | Ensures that all internal signals such as count, wr_ptr, rd_ptr, full, empty, etc., are correctly reset.            |
| full_a                 | An assertion used to check that the full signal is asserted when the FIFO depth is reached.                     | Directed during the design code (FIFO)              |                                             | Validates that the FIFO full flag is asserted when the FIFO reaches its maximum capacity.                           |
| empty_a                | An assertion used to verify that the FIFO's empty signal is asserted when no data is present.                   | Directed during the design code (FIFO)              |                                             | Confirms that the FIFO is indeed empty when the empty flag is high.                                                 |
| almostfull_a           | An assertion used to check that the almostfull signal is correctly asserted when the FIFO is nearly full.       | Directed during the design code (FIFO)              |                                             | Verifies that the FIFO is nearing capacity when almostfull is asserted                                              |
| almostempty_a          | An assertion used to check that the almostempty signal is asserted when only one data word is left in the FIFO. | Directed during the design code (FIFO)              |                                             | Ensures that the FIFO is nearly empty when almostempty is correctly asserted.                                       |
| ack_a                  | An assertion used to ensure that wr_ack is generated only when a write operation is successful.                 | Directed during the design code (FIFO)              |                                             | Verifies that wr_ack is asserted during valid write operations.                                                     |
| overflow_a             | An assertion used to detect when the FIFO overflows upon attempting a write operation while full.               | Directed during the design code (FIFO)              |                                             | Ensures that the FIFO enters overflow only when the FIFO is full and a write attempt is made.                       |
| underflow_a            | An assertion used to catch underflow situations when attempting a read operation on an empty FIFO.              | Directed during the design code (FIFO)              |                                             | Validates that the FIFO enters<br>underflow only when a read<br>operation is attempted while the<br>FIFO is empty.  |
| wr_ptr_a               | An assertion used to track the wr_ptr increment after valid write operations.                                   | Directed during the design code (FIFO)              |                                             | Ensures that the write pointer increments correctly with every valid write operation.                               |
| rd_ptr_a               | An assertion used to track the rd_ptr increment after valid read operations.                                    | Directed during the design code (FIFO)              |                                             | Ensures that the read pointer increments correctly with every valid read operation.                                 |
| count_write_priority_a | An assertion used to verify the counter behavior when write and read enable signals are both active with empty. | Directed during the design code (FIFO)              |                                             | Confirms that the counter increments as expected in this priority case.                                             |
| count_read_priority_a  | An assertion used to verify the counter behavior when both write and read are enabled with the FIFO full.       | Directed during the design code (FIFO)              |                                             | Confirms that the counter decrements as expected in this priority case.                                             |

| count_w_a           | An assertion used to verify that the counter increments with valid writes and no read operations.                                                                                                                                                                                                   | Directed during the design code (FIFO)      |                       | Ensures that the counter increments correctly when a valid write occurs and no read is happening. |  |  |
|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------|-----------------------|---------------------------------------------------------------------------------------------------|--|--|
| count_r_a           | An assertion used to verify that the counter decrements with valid reads and no write operations.                                                                                                                                                                                                   | Directed during the design code (FIFO)      |                       | Ensures that the counter decrements correctly when a valid read occurs and no write is happening. |  |  |
| File                |                                                                                                                                                                                                                                                                                                     | Us                                          | sage                  |                                                                                                   |  |  |
| FIEO OFOLIENCE ITEM | This file has the constraints and defines the transaction object (sequence item) that carries the data signals for write and read operations to/from the FIFO. It abstracts the data transfer operations to the constraints are constraints and read operations to the constraints are constraints. |                                             |                       |                                                                                                   |  |  |
| FIFO SEQUENCE ITEM  | 1                                                                                                                                                                                                                                                                                                   | nd read operations to/from th               | ne FIFO. It abstracts | the data transfer operations.                                                                     |  |  |
| Constraint Name     | 1                                                                                                                                                                                                                                                                                                   | nd read operations to/from the              | Functional            | the data transfer operations.  Functionality Check                                                |  |  |
|                     | signals for write ar                                                                                                                                                                                                                                                                                |                                             | Functional            | ·<br>I                                                                                            |  |  |
| Constraint Name     | Description  A constraint used to control the distribution of rst_n, making reset occur                                                                                                                                                                                                             | Stimulus Generation  Directed at the end of | Functional            | Functionality Check  Ensures that rst_n is mostly high with rare assertions, simulating rare      |  |  |

#### **FIFO UVM Structure:**



#### **How it Works?**

### 1. Top Module (FIFO\_TOP.sv):

This is the highest level of your verification environment. It instantiates the design under test (DUT) and connects the DUT to the UVM testbench. The FIFO\_TOP.sv module also instantiates the FIFO\_IF (interface) and links it to the DUT, ensuring signals between the testbench and the DUT are connected correctly.

#### 2. Interface (FIFO\_IF.sv):

The FIFO\_IF.sv defines the signals that connect to the FIFO DUT. This includes signals like clock, reset, write enable, read enable, data inputs, and outputs. The interface provides a structured mechanism to communicate with the DUT by grouping related signals together and making them accessible to the driver, monitor, and scoreboard.

#### 3. UVM Testbench Flow:

The UVM testbench drives the verification process by generating stimulus, driving it into the DUT, monitoring the outputs, and analyzing the results.

#### 3.1 Configuration (FIFO\_CONFIG.sv)

The configuration object holds parameters like FIFO depth, data width, and other operational settings. This configuration is passed to various components in the testbench to ensure a consistent environment for verification.

#### 3.2 Sequences and Sequence Items

#### FIFO\_SEQUENCE\_ITEM.sv:

This file defines the transaction object (sequence item) that carries the data and control signals for write and read operations to/from the FIFO. It abstracts the data transfer operations.

• FIFO\_RESET\_SEQUENCE.sv, FIFO\_WRITE\_SEQUENCE.sv, FIFO\_READ\_SEQUENCE.sv, FIFO\_WRITE\_READ\_SEQUENCE.sv, FIFO\_MAIN\_SEQUENCE.sv:

These files define different sequences, which are collections of transactions. Each sequence models a specific operation: resetting the FIFO, writing data, reading data, performing combined write-read operations, and orchestrating the overall verification flow (in the main sequence). The main sequence controls the order of operations and ensures different sequences are executed as part of the verification plan.

#### 3.3 Sequencer (FIFO\_SEQUENCER.sv)

The sequencer coordinates the execution of sequences. It sends the transaction (sequence item) to the driver, which will then apply it to the DUT. In your UVM testbench, the FIFO\_SEQUENCER manages the flow of read and write sequences and other operations, ensuring the correct stimulus is generated.

#### 3.4 Driver (FIFO\_DRIVER.sv)

The driver takes the transaction objects from the sequencer and translates them into pin-level activity on the DUT using the interface. It drives the stimulus into the DUT through the FIFO\_IF, such as asserting write or read enable signals, and providing the data input to the FIFO.

#### 3.5 Monitor (FIFO\_MONITOR.sv)

The monitor observes the DUT's signals through the interface. It passively captures the inputs and outputs of the FIFO for analysis without modifying the DUT's behavior. The monitor collects relevant data and forwards it to other components like the coverage collector and scoreboard.

#### 4. Analysis Components

#### 4.1 Scoreboard (FIFO\_SCOREBOARD.sv)

The scoreboard is responsible for checking the functional correctness of the DUT. It compares the expected results (predicted by a reference model or logic) with the actual outputs observed by the monitor. In your project, the FIFO\_SCOREBOARD will verify that the data written into the FIFO is correctly read out and that any underflow or overflow conditions are handled properly.

#### 4.2 Coverage Collector (FIFO\_COVERAGE\_COLLECTOR.sv)

The coverage collector gathers coverage information, tracking how thoroughly the DUT has been tested. It looks at functional coverage metrics like whether all possible write-read combinations, FIFO full/empty conditions, and other critical scenarios have been exercised. This component provides insight into how much of the design has been verified.

#### 5. Environment (FIFO\_ENV.sv)

The environment is the container for all the UVM components, such as agents, scoreboard, and coverage collector. The FIFO\_ENV instantiates the agents that control the driver, monitor, and sequencer and ensures that these components interact correctly. It also connects the environment's agents to the scoreboard and coverage collector.

#### FIFO AGENT.sv:

The agent encapsulates the driver, monitor, and sequencer for the FIFO. It coordinates their activities to ensure the interface is driven correctly and monitored consistently. The agent simplifies managing these components by providing a unified entity to control them.

#### 6. Assertions (FIFO\_SVA.sv)

The assertions module (FIFO\_SVA.sv) defines SystemVerilog assertions (SVA) to check critical design properties. For example, assertions may ensure that the FIFO never overflows or underflows and that data integrity is maintained. These are runtime checks that trigger if the DUT violates any of the expected behaviors.

#### 7. Test (FIFO\_TEST.sv)

The test file (FIFO\_TEST.sv) is where the overall test strategy is defined. This file extends the UVM test class and initiates the execution of the sequences. It configures the environment, runs the main sequence, and ensures the test runs as expected. You may have multiple tests targeting different aspects of the FIFO (e.g., stress tests, boundary condition tests, etc.).

## **Bugs Report:**

Underflow signal bug:

Bug: underflow signal was meant to be sequential (following clock edge) in the Specs

#### Original design:

```
assign full = (count == FIFO_DEPTH)? 1 : 0;
assign empty = (count == 0)? 1 : 0;
assign underflow = (empty && rd_en)? 1 : 0; // here
assign almostfull = (count == FIFO_DEPTH-2)? 1 : 0;
assign almostempty = (count == 1)? 1 : 0;
```

Modification: I made it following clock edge in the read always block

#### Modified design:

```
always @(posedge clk or negedge rst_n) begin
    if (!rst_n) begin
        rd_ptr <= 0;
        underflow <= 0; // was added
    end
    else if (rd_en && count != 0) begin
        data_out <= mem[rd_ptr];
        rd_ptr <= rd_ptr + 1;
        underflow <= 0; // was added
    end
    else begin
        if(empty && rd_en) // this is sequential output not combinational
        underflow = 1;
    else
        underflow = 0;
    end
end</pre>
```

#### • Missing conditions:

Bug: the Spec was "If a read and write enables were high and the FIFO was empty, only writing will take place and vice verse if the FIFO was full" and it was not implemented in the original design

#### Original design:

```
always @(posedge clk or negedge rst_n) begin
    if (!rst_n) begin
        count <= 0;
    end
    else begin
        if (({wr_en, rd_en} == 2'b10) && !full)
              count <= count + 1;
        else if (({wr_en, rd_en} == 2'b01) && !empty)
              count <= count - 1;
    end
end</pre>
```

Modification: I added the right conditions to meet the Specs

#### Modified design:

```
always @(posedge clk or negedge rst_n) begin
    if (!rst_n) begin
        count <= 0;
    end
    else begin
        if (wr_en && rd_en && empty) // this condition was added
            count <= count + 1;
        else if (wr_en && rd_en && full) // this condition was added
            count <= count - 1;
        else if ( ({wr_en, rd_en} == 2'b10) && !full)
            count <= count + 1;
        else if ( ({wr_en, rd_en} == 2'b01) && !empty)
            count <= count - 1;
        end
end</pre>
```

#### Unknown behavior while reset:

Bug: there are some signals which their output haven't been specified when reset signal takes place

#### Original design:

```
always @(posedge clk or negedge rst_n) begin
    if (!rst_n) begin
        wr_ptr <= 0;
    else if (wr_en && count < FIFO_DEPTH) begin
        mem[wr_ptr] <= data_in;</pre>
        wr_ack <= 1;
        wr_ptr <= wr_ptr + 1;
    else begin
        wr_ack <= 0;
        if (full & wr_en)
            overflow <= 1;
        else
            overflow <= 0;
    end
end
always @(posedge clk or negedge rst_n) begin
    if (!rst_n) begin
        rd_ptr <= 0;
    else if (rd_en && count != 0) begin
        data_out <= mem[rd_ptr];</pre>
        rd_ptr <= rd_ptr + 1;
end
```

Modification: I added the right conditions to meet the Specs

#### Modified design:

```
always @(posedge clk or negedge rst_n) begin
    if (!rst n) begin
        wr ptr <= 0;
        wr ack <= 0; // was added
        overflow <= 0; // was added</pre>
    else if (wr_en && count < FIFO_DEPTH) begin
        mem[wr ptr] <= data in;</pre>
        wr_ack <= 1;
        wr_ptr <= wr_ptr + 1;
        overflow <= 0; // was added
    else begin
        wr_ack <= 0;
        if (full & wr_en)
            overflow <= 1;
        else
           overflow <= 0;
end
always @(posedge clk or negedge rst_n) begin
    if (!rst_n) begin
       rd_ptr <= 0;
        underflow <= 0; // was added</pre>
    else if (rd en && count != 0) begin
        data_out <= mem[rd_ptr];</pre>
        rd_ptr <= rd_ptr + 1;
        underflow <= 0; // was added</pre>
    else begin
        if(empty && rd_en) // this is sequential output not combinational
            underflow = 1;
        else
            underflow = 0;
end
```

### **Code Coverage:**

Branch:

```
Branches - by instance (/fifo_top/dut)
FIFO.sv
             47 if (!rst n) begin
             59 if ((count == FIFO DEPTH))
            61 if ((count == 0))
             65 if ((count == FIFO DEPTH - 1))
            67 if ((count == 1))
          131 if (!rst_n) begin
           136 else if (wr en && count < FIFO DEPTH) begin
           142 else begin
           144 if (full & wr en)
           146 else
           152 if (!rst n) begin
           156 else if (rd en && count != 0) begin
           161 else begin
           162 if (empty && rd en) // this is sequential output no combinational
           164 else
           170 if (!rst_n) begin
           173 else begin
           174 if (wr en && rd en && empty) // this condition was added
           176 else if (wr en && rd en && full) // this condition was added
           178 else if ( ({wr_en, rd_en} == 2'bl0) && !full)
           180 else if ( ({wr en, rd en} == 2'b01) && !empty)
           185 assign full = (count == FIFO DEPTH)? 1 : 0;
           186 assign empty = (count == 0)? 1 : 0;
           188 assign almostfull = (count == FIFO DEPTH-1)? 1 : 0;
           189 assign almostempty = (count == 1)? 1: 0;
```

• Toggle:

```
Toggles - by instance (/fifo_top/tb)

sim:/fifo_top/tb

almostempty
almostfull
clk
data_in
data_out
empty
full
overflow
rd_en
rst_n
underflow
wr_ack
wr_en
```

Statement:

```
FIFO.sv
             20 assign clk = fifoif.clk;
             21 assign data in = fifoif.data in;
             22 assign rst n = fifoif.rst n;
             23 assign wr en = fifoif.wr en;
             24 assign rd_en = fifoif.rd_en;
             46 always comb begin // for asynchronous reset
            130 always @(posedge clk or negedge rst_n) begin
            132 wr ptr <= 0;
            133 wr ack <= 0; // was added
            134 overflow <= 0; // was added
            137 mem[wr ptr] <= data in;
            138 wr_ack <= 1;
            139 wr_ptr <= wr_ptr + 1;
            140 overflow <= 0; // was added
            143 wr ack <= 0;
            145 overflow <= 1;
            147 overflow <= 0;
            151 always @(posedge clk or negedge rst n) begin
            153 rd ptr <= 0;
            154 underflow <= 0; // was added
           157 data out <= mem[rd ptr];
            158 rd ptr <= rd ptr + 1;
            159 underflow <= 0; // was added
            163 underflow = 1;
            165 underflow = 0;
            169 always @(posedge clk or negedge rst_n) begin
            171 count <= 0;
       171 count <= 0;
       175 count <= count + 1;
       177 count <= count - 1;
       179 count <= count + 1;
       181 count <= count - 1;
       185 assign full = (count == FIFO_DEPTH)? 1 : 0;
       186 assign empty = (count == 0)? 1 : 0;
       188 assign almostfull = (count == FIFO DEPTH-1)? 1 : 0;
       189 assign almostempty = (count == 1)? 1: 0;
```

# **Functional Coverage (including cross coverage):**

| Name                                 | Class Type                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Coverage | Goal | % of Goal | Status | Include |
|--------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|------|-----------|--------|---------|
|                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 100.0%   |      |           |        |         |
| TYPE FIFO_Cross_Group                | FIFO_cover                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 100.0%   | 100  | 100.0%    |        | _/      |
| CVP FIFO _Cross _Group::cp _wr _en   | FIFO_cover                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 100.0%   | 100  | 100.0%    |        |         |
| B bin auto[0]                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 286      | 1    | 100.0%    |        |         |
| B) bin auto[1]                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 715      | 1    | 100.0%    |        |         |
| CVP FIFO _Cross _Group::cp _rd _en   | FIFO_cover                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 100.0%   | 100  | 100.0%    |        |         |
| B) bin auto[0]                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 721      | 1    | 100.0%    |        |         |
| B) bin auto[1]                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 280      | 1    | 100.0%    |        |         |
| CVP FIFO_Cross_Group::cp_ack         | FIFO_cover                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 100.0%   | 100  | 100.0%    |        |         |
| B bin auto[0]                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 649      | 1    | 100.0%    |        |         |
| B) bin auto[1]                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 352      | 1    | 100.0%    |        |         |
| CVP FIFO_Cross_Group::cp_overflow    | FIFO_cover                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 100.0%   | 100  | 100.0%    |        |         |
| B) bin auto[0]                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 647      | 1    | 100.0%    |        |         |
| B) bin auto[1]                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 354      | 1    | 100.0%    |        |         |
| CVP FIFO_Cross_Group::cp_full        | FIFO_cover                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 100.0%   | 100  | 100.0%    |        |         |
| B) bin auto[0]                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 503      | 1    | 100.0%    |        | -/      |
| B) bin auto[1]                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 498      | 1    | 100.0%    |        |         |
| CVP FIFO_Cross_Group::cp_empty       | FIFO_cover                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 100.0%   | 100  | 100.0%    |        |         |
| B) bin auto[0]                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 979      | 1    | 100.0%    |        |         |
| B) bin auto[1]                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 22       | 1    | 100.0%    |        |         |
| CVP FIFO_Cross_Group::cp_almostfull  | FIFO_cover                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 100.0%   | 100  | 100.0%    |        |         |
| B) bin auto[0]                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 732      | 1    | 100.0%    |        | -/      |
| B) bin auto[1]                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 269      | 1    | 100.0%    |        |         |
| CVP FIFO_Cross_Group::cp_almostempty | FIFO_cover                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 100.0%   | 100  | 100.0%    |        |         |
| B) bin auto[0]                       | and the second s | 965      | 1    | 100.0%    |        | -       |
| B) bin auto[1]                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 36       | 1    | 100.0%    |        |         |
| CVP FIFO_Cross_Group::cp_underflow   | FIFO_cover                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 100.0%   | 100  | 100.0%    |        | -/      |
| B) bin auto[0]                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 993      | 1    | 100.0%    |        |         |
| B) bin auto[1]                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 8        | 1    | 100.0%    |        |         |
|                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |          |      | 4         |        |         |

| ▼ Name                                                                                                              | Class Type | Coverage        | Goal | % of Goal | Status | Included    |
|---------------------------------------------------------------------------------------------------------------------|------------|-----------------|------|-----------|--------|-------------|
|                                                                                                                     | FIFO_cover | 100.0%          | 100  | 100.0%    |        | <b>-</b>    |
| □-    □    CROSS FIFO_Cross_Group::wr_ack_C                                                                         | FIFO_cover | 100.0%          | 100  | 100.0%    |        | <b>-</b>    |
| B bin <auto[0],auto[0]></auto[0],auto[0]>                                                                           |            | 192             |      | 100.0%    |        | <b>■</b> ✓  |
| B bin <auto[1],auto[0],auto[0]></auto[1],auto[0],auto[0]>                                                           |            | 287             |      | 100.0%    |        | ■ ✓.        |
| B bin <auto[0],auto[1],auto[0]></auto[0],auto[1],auto[0]>                                                           |            | 94              |      | 100.0%    |        | ■ ✓.        |
| B bin <auto[1],auto[1],auto[0]></auto[1],auto[1],auto[0]>                                                           |            | 76              |      | 100.0%    |        |             |
| B bin <auto[1],auto[0],auto[1]></auto[1],auto[0],auto[1]>                                                           |            | 242             |      | 100.0%    |        | ■ <         |
| B bin <auto[1],auto[1],auto[1]> B illegal_bin zero_zero_one</auto[1],auto[1],auto[1]>                               |            | 110<br>0        |      | 100.0%    |        | ■ </td      |
| ☐- CROSS FIFO_Cross_Group::overflow_C                                                                               | FIFO_cover | 100.0%          |      | 100.0%    |        | <b>-</b>    |
| B) bin <auto[0],auto[0],auto[0]></auto[0],auto[0],auto[0]>                                                          | TITO_COVET | 192             |      | 100.0%    |        | <b>-</b>    |
| B) bin <auto[1],auto[0],auto[0]></auto[1],auto[0],auto[0]>                                                          |            | 249             |      | 100.0%    |        | <b>-</b>    |
| B bin <auto[0],auto[1],auto[0]></auto[0],auto[1],auto[0]>                                                           |            | 94              |      | 100.0%    |        | <b>=</b> >  |
| B) bin <auto[1],auto[1],auto[0]></auto[1],auto[1],auto[0]>                                                          |            | 112             | 1    | 100.0%    |        |             |
| B bin <auto[1],auto[0],auto[1]></auto[1],auto[0],auto[1]>                                                           |            | 280             | 1    | 100.0%    |        | <b>-</b>    |
| B bin <auto[1],auto[1],auto[1]></auto[1],auto[1],auto[1]>                                                           |            | 74              | 1    | 100.0%    |        | <b>-</b>    |
| B illegal_bin zero_w_one                                                                                            |            | 0               | -    | -         |        | 1           |
| □-      □ CROSS FIFO_Cross_Group::full_C                                                                            | FIFO_cover | 100.0%          | 100  | 100.0%    |        | <b>-</b>    |
| B bin <auto[0],auto[0]></auto[0],auto[0]>                                                                           |            | 100             |      | 100.0%    |        | ■ 🗸         |
| B bin <auto[0],auto[1],auto[0]></auto[0],auto[1],auto[0]>                                                           |            | 94              |      | 100.0%    |        | ■ ✓.        |
| B bin <auto[1],auto[0],auto[0]></auto[1],auto[0],auto[0]>                                                           |            | 123             |      | 100.0%    |        | ■ ✓.        |
| B bin <auto[1],auto[1],auto[0]></auto[1],auto[1],auto[0]>                                                           |            | 186             |      | 100.0%    |        |             |
| B bin <auto[0],auto[0],auto[1]></auto[0],auto[0],auto[1]>                                                           |            | 92              |      | 100.0%    |        | <b>■</b> ✓  |
| B) bin <auto[1],auto[0],auto[1]> B) illegal_bin one_r_one</auto[1],auto[0],auto[1]>                                 |            | <b>406</b><br>0 |      | 100.0%    |        | ■ 🗸         |
| ☐ CROSS FIFO Cross Group::empty_C                                                                                   | FIFO_cover | 100.0%          |      | 100.0%    |        | <b>-</b>    |
| B) bin <auto[0],auto[0],auto[0]></auto[0],auto[0],auto[0]>                                                          | 11 O_cover | 186             |      | 100.0%    |        | ■*/         |
| B) bin <auto[1],auto[0],auto[0]></auto[1],auto[0],auto[0]>                                                          |            | 522             |      | 100.0%    |        | <b>-</b>    |
| B bin <auto[0],auto[1],auto[0]></auto[0],auto[1],auto[0]>                                                           |            | 87              |      | 100.0%    |        | <b>=</b> >  |
| B) bin <auto[1],auto[1],auto[0]></auto[1],auto[1],auto[0]>                                                          |            | 184             | 1    | 100.0%    |        |             |
| B] bin <auto[0],auto[0],auto[1]></auto[0],auto[0],auto[1]>                                                          |            | 6               | 1    | 100.0%    |        | <b>-</b>    |
| B bin <auto[1],auto[0],auto[1]></auto[1],auto[0],auto[1]>                                                           |            | 7               | 1    | 100.0%    |        | <b>-</b>    |
| B bin <auto[0],auto[1],auto[1]></auto[0],auto[1],auto[1]>                                                           |            | 7               | 1    | 100.0%    |        | <b>■</b> 🗸  |
| B bin <auto[1],auto[1]></auto[1],auto[1]>                                                                           |            | 2               | 1    | 100.0%    |        | ■ 🗸         |
| CROSS FIFO_Cross_Group::almostfull_C                                                                                | FIFO_cover | 100.0%          | 100  | 100.0%    |        | <b>-</b> /  |
| B) bin <auto[0],auto[0],auto[0]></auto[0],auto[0],auto[0]>                                                          |            | 129             | 1    | 100.0%    |        | <b>-</b>    |
| B bin <auto[1],auto[0],auto[0]></auto[1],auto[0],auto[0]>                                                           |            | 499             | 1    |           |        | <b>■</b> ✓  |
| B bin <auto[0],auto[1],auto[0]></auto[0],auto[1],auto[0]>                                                           |            | 48              |      |           |        | ■ 🗸         |
| B) bin <auto[1],auto[1],auto[0]></auto[1],auto[1],auto[0]>                                                          |            | 56              |      |           |        | ■√.         |
| B bin <auto[0],auto[1]></auto[0],auto[1]>                                                                           |            | 63              |      |           |        | ■ <         |
| B bin <auto[1],auto[0],auto[1]></auto[1],auto[0],auto[1]>                                                           |            | 30              |      |           |        |             |
| B bin <auto[0],auto[1],auto[1]> B bin <auto[1],auto[1],auto[1]></auto[1],auto[1],auto[1]></auto[0],auto[1],auto[1]> |            | 46<br>130       |      |           |        |             |
| CROSS FIFO_Cross_Group::almostempty_C                                                                               | FIFO_cover |                 |      |           |        | <b>-</b>    |
| B) bin <auto[0],auto[0]></auto[0],auto[0]>                                                                          | 110_0000   | 184             |      |           |        | <b>-</b>    |
| B) bin <auto[1],auto[0],auto[0]></auto[1],auto[0],auto[0]>                                                          |            | 519             |      |           |        | <b>=</b> >  |
| B) bin <auto[0],auto[1],auto[0]></auto[0],auto[1],auto[0]>                                                          |            | 90              | 1    | 100.0%    |        | <b>=</b> ~  |
| B bin <auto[1],auto[1],auto[0]></auto[1],auto[1],auto[0]>                                                           |            | 172             | 1    | 100.0%    |        | <b>-</b>    |
| B bin <auto[0],auto[0],auto[1]></auto[0],auto[0],auto[1]>                                                           |            | 8               | 1    | 100.0%    |        | <b>-</b>    |
| B bin <auto[1],auto[0],auto[1]></auto[1],auto[0],auto[1]>                                                           |            | 10              | 1    |           |        | <b>-</b>    |
| B bin <auto[0],auto[1],auto[1]></auto[0],auto[1],auto[1]>                                                           |            | 4               |      |           |        | <b>-</b>    |
| B) bin <auto[1],auto[1]></auto[1],auto[1]>                                                                          |            | 14              |      |           |        | <b>■</b> ✓. |
| ☐-☐ CROSS FIFO_Cross_Group::underflow_C                                                                             | FIFO_cover |                 |      |           |        | <b>-</b>    |
| B bin <auto[0],auto[0],auto[0]></auto[0],auto[0],auto[0]>                                                           |            | 192             |      |           |        | <b>■</b> ✓  |
| B bin <auto[0],auto[1],auto[0]> B bin <auto[1],auto[0],auto[0]></auto[1],auto[0],auto[0]></auto[0],auto[1],auto[0]> |            | 91<br>529       |      |           |        | <b>■</b> ✓  |
| B bin <auto[1],auto[0],auto[0]></auto[1],auto[0],auto[0]>                                                           |            | 181             |      |           |        |             |
| B) bin <auto[1],auto[1],auto[1]></auto[1],auto[1],auto[1]>                                                          |            | 3               |      |           |        |             |
| B) bin <auto[1],auto[1],auto[1]></auto[1],auto[1],auto[1]>                                                          |            | 5               |      |           |        | <b>■</b> ✓  |
| B) illegal_bin zero_r_one                                                                                           |            | 0               |      |           |        |             |
|                                                                                                                     |            |                 |      |           |        | •           |

# **Assertions Coverage:**

| ▼ Name                               | Language | Enabled  | Log | Count | AtLeast | Limit     | Weight | Cmplt % | Cmplt graph | Included |
|--------------------------------------|----------|----------|-----|-------|---------|-----------|--------|---------|-------------|----------|
| /fifo_top/dut/ack_c                  | SVA      | <b>√</b> | Off | 349   | 1       | Unlimited | 1      | 100%    |             | ✓        |
| /fifo_top/dut/overflow_c             | SVA      | 1        | Off | 349   | 1       | Unlimited | 1      | 100%    |             | <b>-</b> |
| /fifo_top/dut/underflow_c            | SVA      | 1        | Off | 8     | 1       | Unlimited | 1      | 100%    |             | <b>√</b> |
| /fifo_top/dut/wr_ptr_c               | SVA      | 1        | Off | 349   | 1       | Unlimited | 1      | 100%    |             | <b>V</b> |
| /fifo_top/dut/rd_ptr_c               | SVA      | 1        | Off | 267   | 1       | Unlimited | 1      | 100%    |             | <b>√</b> |
| /fifo_top/dut/count_write_priority_c | SVA      | 1        | Off | 5     | 1       | Unlimited | 1      | 100%    |             | <b>√</b> |
| /fifo_top/dut/count_read_priority_c  | SVA      | 1        | Off | 73    | 1       | Unlimited | 1      | 100%    |             | <b>√</b> |
| /fifo_top/dut/count_w_c              | SVA      | 1        | Off | 240   | 1       | Unlimited | 1      | 100%    |             | <b>-</b> |
| /fifo_top/dut/count_r_c              | SVA      | 1        | Off | 90    | 1       | Unlimited | 1      | 100%    |             | <b>/</b> |

## **Assertions Passed:**

|                                    | Assertion Ty         | /p Language | Enable Failure | Cou Pass Count | Active Cou | Memo | P Peak | Cu ATV | Assertion Expression                                                                                 |
|------------------------------------|----------------------|-------------|----------------|----------------|------------|------|--------|--------|------------------------------------------------------------------------------------------------------|
| ▲ /fifo_top/dut/count_aa           | Immediate            | SVA         | on             | 0 1            | -          | -    |        | off    | assert (count==0)                                                                                    |
| /fifo_top/dut/wr_ptr_aa            | Immediate            | SVA         | on             | 0 1            |            | -    |        | off    | assert (wr_ptr==0)                                                                                   |
| <pre>/fifo_top/dut/rd_ptr_aa</pre> | Immediate            | SVA         | on             | 0 1            |            |      |        | off    | assert (rd_ptr==0)                                                                                   |
| /fifo_top/dut/full_aa              | Immediate            | SVA         | on             | 0 1            | -          |      |        | off    | assert (full==0)                                                                                     |
| /fifo_top/dut/empty_aa             | Immediate            | SVA         | on             | 0 1            | -          | -    |        | off    | assert (empty==1)                                                                                    |
| /fifo_top/dut/underflow_aa         | Immediate            | SVA         | on             | 0 1            |            | -    |        | off    | assert (underflow==0)                                                                                |
| /fifo_top/dut/almostfull_aa        | Immediate            | SVA         | on             | 0 1            |            |      |        | off    | assert (almostfull==0)                                                                               |
| /fifo_top/dut/almostempty_aa       | Immediate            | SVA         | on             | 0 1            | -          | -    |        | off    | assert (almostempty==0)                                                                              |
| /fifo_top/dut/wr_ack_aa            | Immediate            | SVA         | on             | 0 1            | -          | -    |        | off    | assert (wr_ack==0)                                                                                   |
| /fifo_top/dut/overflow_aa          | Immediate            | SVA         | on             | 0 1            | -          | -    |        | off    | assert (overflow==0)                                                                                 |
| /fifo_top/dut/full_a               | Immediate            | SVA         | on             | 0 1            | -          |      |        | off    | assert (full==1)                                                                                     |
| /fifo_top/dut/empty_a              | Immediate            | SVA         | on             | 0 1            | -          | -    |        | off    | assert (empty==1)                                                                                    |
| /fifo_top/dut/almostfull_a         | Immediate            | SVA         | on             | 0 1            |            |      |        | off    | assert (almostfull==1)                                                                               |
| /fifo_top/dut/almostempty_a        | Immediate            | SVA         | on             | 0 1            | -          |      |        | off    | assert (almostempty==1)                                                                              |
| /fifo_top/dut/ack_a                | Concurrent           | SVA         | on             | 0 1            | -          | 0B.  |        | off    | assert(@(posedge clk) disable iff (rst_n==0) (((wr_en&&count<8)) =>wr_ack))                          |
| /fifo_top/dut/overflow_a           | Concurrent           | SVA         | on             | 0 1            | -          | 0B.  |        | off    | assert( @(posedge clk) disable iff (rst_n==0) (((count==8&≀_en)) =>overflow==1))                     |
| /fifo_top/dut/underflow_a          | Concurrent           | SVA         | on             | 0 1            | -          | 0B.  |        | off    | assert(@(posedge clk) disable iff (rst_n==0) (((empty&&rd_en)) =>underflow))                         |
| /fifo_top/dut/wr_ptr_a             | Concurrent           | SVA         | on             | 0 1            | -          | 0B.  |        | off    | assert(@(posedge clk) disable iff (rst_n==0) (((wr_en&&count<8)) =>wr_ptr==\$past(wr_ptr)+1))        |
| /fifo_top/dut/rd_ptr_a             | Concurrent           | SVA         | on             | 0 1            | -          | 0B.  |        | off    | assert( @(posedge clk) disable iff (rst_n==0) (((rd_en&&count!=0)) =>rd_ptr==\$past(rd_ptr)+1))      |
| /fifo_top/dut/count_write_priority | _a Concurrent        | SVA         | on             | 0 1            | -          | 0B.  |        | off    | assert(@(posedge clk) disable iff (rst_n==0) ((((wr_en&&rd_en)&∅))) =>count==\$past(count)+1))       |
| /fifo_top/dut/count_read_priority_ | a Concurrent         | SVA         | on             | 0 1            | -          | 0B.  |        | off    | assert(@(posedge clk) disable iff (rst_n==0) ((((wr_en&&rd_en)&&full)))=>count==\$past(count)-1))    |
| /fifo_top/dut/count_w_a            | Concurrent           | SVA         | on             | 0 1            |            | 0B.  |        | off    | assert( @(posedge clk) disable iff (rst_n==0) ((((wr_en&&~rd_en)&&~full)) =>count==\$past(count)+1)) |
| /fifo_top/dut/count_r_a            | Concurrent           | SVA         | on             | 0 1            |            | 0B.  |        | off    | assert(@(posedge clk) disable iff (rst_n==0) ((((~wr_en&&rd_en)&&~empty))) =>count==\$past(count)-1) |
| /fifo top/tb/#ublk#217929410#3     | B/immed 39 Immediate | SVA         | on             | 0 1            |            | -    |        | off    | assert (randomize())                                                                                 |

| /fifo_top/dut/count_aa                                                  | INACTIVE |              |                 |             |                        |                 |             |                |              |
|-------------------------------------------------------------------------|----------|--------------|-----------------|-------------|------------------------|-----------------|-------------|----------------|--------------|
| /fifo_top/dut/wr_ptr_aa                                                 | INACTIVE |              |                 |             |                        |                 |             |                |              |
| /fifo_top/dut/rd_ptr_aa                                                 | INACTIVE |              |                 |             |                        |                 |             |                |              |
| /fifo_top/dut/full_aa                                                   | INACTIVE |              |                 |             |                        |                 |             |                |              |
| /fifo_top/dut/empty_aa                                                  | INACTIVE |              |                 |             |                        |                 |             |                |              |
| /fifo_top/dut/underflow_aa                                              | INACTIVE |              |                 |             |                        |                 |             |                |              |
| /fifo_top/dut/almostfull_aa                                             | INACTIVE |              |                 |             |                        |                 |             |                |              |
| /fifo_top/dut/almostempty_aa                                            | INACTIVE |              |                 |             |                        |                 |             |                |              |
| /fifo_top/dut/wr_ack_aa                                                 | INACTIVE |              |                 |             |                        |                 |             |                |              |
| /fifo_top/dut/overflow_aa                                               | INACTIVE |              |                 |             |                        |                 |             |                |              |
| /fifo_top/dut/full_a                                                    | INACTIVE |              |                 |             |                        |                 |             |                |              |
| <b>I /</b> /fifo_top/dut/empty_a                                        | INACTIVE |              |                 |             |                        |                 |             |                |              |
| /fifo_top/dut/almostfull_a                                              | INACTIVE |              |                 |             |                        |                 |             |                |              |
| <b>■</b> /fifo_top/dut/almostempty_a                                    | INACTIVE |              |                 |             |                        |                 |             |                |              |
| /fifo_top/dut/ack_a                                                     | ACTIVE   |              | WILLIAM THE LA  |             | MUNICIPAL III. III.    | WILLIAM WILLIAM |             |                | munus en min |
| /fifo_top/dut/overflow_a                                                | INACTIVE |              |                 |             |                        |                 |             |                |              |
| /fifo_top/dut/underflow_a                                               | INACTIVE |              |                 |             |                        |                 |             |                |              |
| ☐ /fifo_top/dut/wr_ptr_a  ☐ / If | ACTIVE   |              | UILLUIT TIIL LL |             | MUNICIPAL III. III.    | nacumumumuma    |             | CHURT URBILLER | muuuu mn     |
| /fifo_top/dut/rd_ptr_a                                                  | ACTIVE   | a mananana   |                 |             | NAME OF TAXABLE PARTY. | CHEVILLIANIA    | LL BOULDELL |                | and the same |
| /fifo_top/dut/count_write_priority_a                                    | INACTIVE |              |                 |             |                        |                 |             |                |              |
| /fifo_top/dut/count_read_priority_a                                     | INACTIVE |              |                 |             |                        |                 |             |                |              |
| /fifo_top/dut/count_w_a                                                 | INACTIVE | IT-THE HOUSE |                 | (ar.a. a.ua |                        |                 |             |                |              |
| /fifo_top/dut/count_r_a                                                 | INACTIVE |              |                 | (u          |                        |                 |             |                |              |

## **Snippets:**

### • Write only sequence:



#### • Read only sequence:



• Both Write and Read Sequence:

| וווס_נסטורס וו ולוססופט_סווול <b>\</b> | 321100000010          | 00000010           |                |
|----------------------------------------|-----------------------|--------------------|----------------|
| /fifo_top/DUT/FIFO_DEPTH               | 32'h00000008          | 00000008           |                |
| /fifo_top/DUT/max_fifo_addr            | 32'h00000003          | 00000003           |                |
| /fifo_top/DUT/dk                       | 1'h0                  |                    |                |
| +/ /fifo_top/DUT/data_in               | 16'h495c              |                    |                |
| /fifo_top/DUT/rst_n                    | 1'h1                  |                    |                |
| /fifo_top/DUT/wr_en                    | 1'h1                  |                    |                |
| /fifo_top/DUT/rd_en                    | 1'h1                  |                    |                |
|                                        | 16'h7ae8              | (5212 ) ( ) ( )    | ( ) ( ) ( 5    |
| /fifo_top/DUT/wr_ack                   | 1h1                   |                    |                |
| /fifo_top/DUT/overflow                 | 1'h0                  |                    |                |
| /fifo_top/DUT/full                     | 1'h0                  |                    |                |
| /fifo_top/DUT/empty                    | 1'h0                  |                    |                |
| /fifo_top/DUT/almostfull               | 1'h0                  |                    |                |
| /fifo_top/DUT/almostempty              | 1'h1                  |                    |                |
| /fifo_top/DUT/underflow                | 1'h0                  |                    |                |
| =                                      | 16'h5212 16'h846      | 5212 84            | (2             |
| <b></b>                                | 16'h5212              | 5212               | 28bd           |
| <b>±</b> - <b>分</b> [6]                | 16'h8465              | 8465               | 495c           |
| <b></b>                                | 16'h <del>4e</del> c5 | 998d (4ec          | :5             |
| <b></b>                                | 16'h7ae8              | 7b0d , 7ae8        |                |
| <b></b>                                | 16'h96ce              | 5663 (96ce         |                |
| <b></b>                                | 16'h69f2              | d609 (69f2         |                |
| <b></b>                                | 16'hdb8f              | 5e81 db8f          | (2             |
| <b>₫- (</b> 0)                         | 16'hd612              | 3524 (d612         | ( <b>5</b> 82d |
|                                        | 3'h6                  | 0 (1,2)3,4,5,6     |                |
| -/ /fifo_top/DUT/rd_ptr                | 3'h5                  | (0 (1)(2)(3)(4)(5) | 6 7 0 1        |
| #                                      | 4h1                   | (0 )(1             |                |

#### • Main (Randomization) Sequence:

#### o Random Snippet:



#### o Random Snippet:



#### o Random Snippet:



#### o Random Snippet:



## **Assertions Table:**

|   | Feature                                                                         | Assertion                                                                                                  |
|---|---------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|
|   | After reset, DUT.count should be 0                                              | assert final(DUT.count == 0);                                                                              |
|   | After reset, DUT.wr_ptr should be 0                                             | assert final(DUT.wr_ptr == 0);                                                                             |
|   | After reset, DUT.rd_ptr should be 0                                             | assert final(DUT.rd_ptr == 0);                                                                             |
|   | After reset, FIFO full flag should be 0                                         | assert final(fifoif.full == 0);                                                                            |
|   | After reset, FIFO empty flag should be 1                                        | assert final(fifoif.empty == 1);                                                                           |
|   | After reset, FIFO underflow flag should be 0                                    | assert final(fifoif.underflow == 0);                                                                       |
|   | After reset, FIFO almost full flag should be 0                                  | assert final(fifoif.almostfull == 0);                                                                      |
|   | After reset, FIFO almost empty flag should be 0                                 | assert final(fifoif.almostempty == 0);                                                                     |
| ) | After reset, FIFO write acknowledge (wr_ack) should be 0                        | assert final(fifoif.wr_ack == 0);                                                                          |
| 1 | After reset, FIFO overflow flag should be 0                                     | assert final(fifoif.overflow == 0);                                                                        |
| 2 | FIFO is full when DUT.count equals FIFO_DEPTH                                   | assert final(fifoif.full == 1);                                                                            |
| 3 | FIFO is empty when DUT.count equals 0                                           | assert final(fifoif.empty == 1);                                                                           |
| 4 | FIFO is almost full when DUT.count equals FIFO_DEPTH - 1                        | assert final(fifoif.almostfull == 1);                                                                      |
| 5 | FIFO is almost empty when DUT.count equals 1                                    | assert final(fifoif.almostempty == 1);                                                                     |
| 5 | Write acknowledge should be asserted when write is enabled and FIFO is not full | `@(posedge fifoif.clk) disable iff (fifoif.rst_n == 0) fifoif.wr_en && (DUT.count < FIFO_DEPTH)            |
| 7 | Overflow flag should be set when FIFO is full and write enable is asserted      | `@(posedge fifoif.clk) disable iff (fifoif.rst_n == 0) ((DUT.count == FIFO_DEPTH) && fifoif.wr_en)         |
| 3 | Underflow flag should be set when FIFO is empty and read enable is asserted     | `@(posedge fifoif.clk) disable iff (fifoif.rst_n == 0) (fifoif.empty) && (fifoif.rd_en)                    |
| ) | Write pointer should increment on write when FIFO is not full                   | `@(posedge fifoif.clk) disable iff (fifoif.rst_n == 0) (fifoif.wr_en) && (DUT.count < FIFO_DEPTH)          |
|   | Read pointer should increment on read when FIFO is not empty                    | `@(posedge fifoif.clk) disable iff (fifoif.rst_n == 0) (fifoif.rd_en) && (DUT.count != 0)                  |
| 1 | Priority for write over read when FIFO is empty                                 | `@(posedge fifoif.clk) disable iff (fifoif.rst_n == 0) (fifoif.wr_en) && (fifoif.rd_en) && (fifoif.empty)  |
| 2 | Priority for read over write when FIFO is full                                  | `@(posedge fifoif.clk) disable iff (fifoif.rst_n == 0) (fifoif.wr_en) && (fifoif.rd_en) && (fifoif.full)   |
| 3 | Count should increment on write when no read is happening                       | `@(posedge fifoif.clk) disable iff (fifoif.rst_n == 0) (fifoif.wr_en) && (!fifoif.rd_en) && (!fifoif.full) |
| 4 | Count should decrement on read when no write is happening                       | `@(posedge fifoif.clk) disable iff (fifoif.rst_n == 0) (!fifoif.wr_en) && (fifoif.rd_en)                   |